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Cortex Software is dedicated to providing technology 
products which are inherently superior by virtue of their 
fundamental design. 
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boolean CheckForlsolation(int centralThouqht, mt targetThought) 

I 

//this function checks if centralThought is related to targetThought 
// via any of targetThought's relations (not directly) 

//remove centralThought as a direct relation fronn targetThought 
RemoveRelation(targetThought, centralThought); 

//create an empty thought list to keep track of the search 
intList searchList=CreateEmptyList(); 

//start recursive searches on each of targetThought's direct relations 
int relation=GetFirstRelation(targetThought); 
boolean found; 
do I 

found=Search(relation, centralThought, searchList); 
if(found) I 

//centralThought was found, no need to search any further 
break; 

\ 

//this loop will end when there are no more relations 
] while{relGtion=GetNextReiation(targetThought); 

//add centralThought back onto targetThought as a relation 
AddRelation(targetThought, centralThought); 

return found; 

! 

FIG. 10a 



10/37 



Figure 10, cont'd 

boolean Search(source, dest, seachList) 
I 

if(Find(source, searchList)) | 

//source has already been searched 
return FALSE; 



//add source to the searchList 
Add(source, searchList) 

if(source =dest) \ 

//this is the destination.we have found i 
return TRUE; 



//recursive searches on each of sources direct relations 
int relation=GetFirstRelation(source); 
boolean found; 
do I 

found=Search(relation, dest, searchList); 
if(found) j 

//centralThought was found, no need to search any further 
break; 

1 

//this loop will end when there are no more relations 
j whiie(relation=GetNextRelation(targetThought); 

return found; 
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There ore very few applications that are useful to olnnost everyone. Actually, 
there is currently only one: the word processor. 




The Brain will be a universally appealing application. It will be one of the nnost 
significant new technologies in decades. The first only thought processor. 
Software that does for thoughts what the word processor does for words. 




The Brain approaches the computer as a computer, not a glorified typewriter, 
calculator, filing cabinet, or day-book. Not surprisingly, the basis of most 
productivity applications are concepts from the pre-computer age. By starting 
with mundane, non-revolutionary task metaphors, these applications are all 
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ForgetThought (fNum) 

//mark all the children of the selected thought 
list.ClearQ; 

MarkChildren (fNum, list); 

//unmark the active thought 

list, RemoveThought (activelhought); 

//unmark thoughts with unmarked parents 

INum = list.GetFirstNumO; 

while(INum != 0) 

^ if(lNum != fNum) //don't unmark the selected thought 



pNum = GetFirstThoughtParent (INum); 
whiie(pNum != 0) 

^ if(list.Contains(pNum) == FALSE) 
I 

if(lsThoughtlnLongTermMemory (pNum) == FALSE) 



//unmark all the children of the unmarked parent 
chiidList.ClearO; 

MarkChildren(pNum, childList); 
list.RemoveList(childList); 



pNum = GetNextThoughtParent(INum); 



INum = list.GetNextNumO; 

//now forget all the thoughts left on the list 
INum = list.GetFirstNumO; 
while(lNum != 0) 



ForgetThought(INum); 
INum = list.GetNextNumO; 



RememberThouqht(rNum) 



//mark oil ttie children of the selected thought 
list.ClearO; 

1 



MarkChildren(rNum, list); 
// remember ail the thoughts on 
1Num = list.GetFirstNumO; 
while(INum != 0) 
\ 

RememberThought(iNum); 
1Num = list.GetNextNumO; 



MarkChildren(num, list) 

{ 

list.AddThought(num); 
cNum = GetFirstChild(num); 
while(cNum != 0) 

\ 

MarkChildren(cNum, list); 
cNum = GetNextChild(num); 
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Algorithm for drawing the plex with distant thoughts 
1. Create a list of thoughts to be drown and their on screen locations: 



2. 


Add 


the central thought to the list. 


3. 


Add 


children to the list. 


4. 


Add 


parents to the list. 


5. 


Add 


jumps to the list. 


6. 


Add 


siblings to the list, checking first that they are not 






already on the list. 


7. 


Add 


distants of children to the list, checking first that they 






are not already on the list. 


8. 


Add 


distants of parents to the list, checking first that they 






are not already on the list. 


9. 


Add 


distants of junnps to the list, checking first that they 






ore not already on the list. 


10. 


Add 


distants of siblings to the list, checking first that 






they are not already on the list. 



11. Draw the lines that connect each thought: 

12. For each item in the list: 

13. Get each item in the list: 

14. If the two items are related, draw lines 

between them from and to the appropriate 
gates. 

15. Draw the distant thoughts: 



16. For each item in the list: 

17. If it is a distant thought, draw it. 

18. Draw the other thoughts: 

19. For each item in the list: 

20. If it is not a distant thought, draw it. 
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line connects the method for searching thoughts 

lines to find a route from nSrc to nDest other than a direct relation 

returns TRUE if found 

boolean SeQrch(int nSrc. int nDest) 



//create the lists 
ThoughtList posList; 
ThoughtList notList; 
//empty the lists 

posList.lnitializeQ; 

notList.lnitialize(); 

//add the source to the not list since we connot go directly to the destination 
notList.Add(nSrc); 

//since we cannot go directly to the destination, 
//add all relates except the destination to the p 

Thought src(nSrc); 

for(int n = 0; ; n++) 

^ int nRel = src.GetRelote(n); 
if(!nRel) 



list of thoughts that possibly connect 
list of thought that do not connect 



ble list 



//no more relations, done 
break; 

if(nRel != nOest) 

//add it to the possibly connect list 
, posList.Add(nRel); 



while(TRUE) 



int nRel = test.GetRelate{n); 
if(!nRel) 

^ //no more relations, done 

I break; 

if(!notList.Exists{nRel}) 

1 

//not checked yet, add to possible list 
posList.Add(rel); 



//check the first possibility 
int nTest = posList.GetFirst(); 
if(lnTest} 

^ //nothing on the list, done 
break; 

I 

Thought test(nTest); 
if(test.lsRelated(nDest)) 

^ //this one is related to the destination, we're done 
I return TRUE: 

//does not connect, add it to the does not connect list 
notList.Add(nTest); 

//add all related thoughts except those already checked to possible list 
for(int n = 0; ;++) 



//remove this one from the possible list 
posList.Remove(nTest); 

// we've checked everything there is 
no other way to get from nSrc to nDest 
return FALSE: 
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